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1 486WB OVERVIEW (82C491/82C392/82C206 CHIPSET) 


1.1 Introduction 


The OPTi 486WB is a three-chip solution offering optimal performance for high-end, 486-based 
AT systems. The OPTi 486WB is designed for systems running from 33 Mhz, to 40 Mhz, and 
up to 50 Mhz and combines three major functions: the 82C491 System Controller (SYSC), the 
82C392 Data Buffer Controller (DBC), and the 82C206 Integrated Peripheral Controller (IPC). 
Refer to the data book supplied by your third-party source for information on the 82C206. 


1.2 Features 
OPTi 486WB features include: 


1X clock source, supporting systems running up to 50 Mhz 

two 160-pin CMOS Plastic Flat Package (PFP), and one 84-pin PLCC 
Copy-Back Direct-Mapped Cache with size of 64 KB, 128 KB, 256 KB and 512 KB 
up to 10% performance enhancement from write-through cache scheme 
supports 2,1,1,1 cache burst cycle as well as 3,1,1,1 cycle 

on-chip comparitor determines cache hit or miss 

up to 64-MB of local high-speed, page-mode, DRAM memory space 
burst-line-fill during Cache-Read-Miss 

control of two non-cacheable regions 

shadow RAM support 

optional caching of shadowed Video BIOS 

hidden refresh 

slow refresh available for a laptop application. 

8042 emulation for fast CPU-reset and gateA20 generation 

turbo/slow speed selection 

AT bus clock selectable from CLKIN/4 or CLKIN/6 

0 or 1 wait state selectable for 16-bit AT bus cycle 

CAS# before RAS# refresh reduces power comsumption 

optional 0 or 1 wait state for Cache-Write-Hit 

WEITEK 4167 coprocessor support 


eoooooo0aoaoeaoaaaaaaaaaa0 Oo 


1.3 SYSTEM BLOCK DIAGRAM 


Figure 1 is a block diagram of a 486WB-based system 


Figure 1. 486WB Based System Block Diagram 


2 82C491 SYSTEM CONTROLLER (SYSC) 


2.0 Features 


The SYSC is a 160-pin PFP (Plastic Flat Package) device. The SYSC integrates a write-back- 
cache controller, local DRAM control, AT bus interface, and CPU interface. 82C491 features 
include: 


CPU reset control 

CPU internal cache control 

CPU burst mode control 

CPU interface control. 

integrated write-back cache controller with tag comparitor. 
page-mode DRAM controller 

burst line fill control logic 

two noncacheable address comparators 

decoupling refresh for local DRAM and AT-bus memory 

2 DMA upper address latches 


ooo0o0o0o0qo0o000 


2.1 Reset Logic 


The SYSC handles two reset inputs, RST1# and RST2#, to generate the CPU reset signal, 
CPURST. RST1# is a "cold reset". output by the DBC when either PWRGD# (Powergood) 
goes low (from the power supply and indicating a low power condition) or the system reset 
button is pressed. RST2# is a "warm reset," asserted by a keyboard reset (CNTL + ALT + 
DEL simultaneously). Note that the keyboard reset is at first handled by either the keyboard 
controller (8042 or 8742 IC) or the DBC, and using the DBC may be advantageous, because it 
routes the reset faster to the SYSC. 


A software reset is also available. Programming bit 0 (from Ob to 1b) of Index Register 20h, 
then executing a "HALT" instruction causes the CPU to assert CPURST. 


2.2 System Clock Generation 


The SYSC has two high frequency clock inputs, CLKI and CLK2I. CLK2I clocks the internal 
cache controller. CLKI, which is driven by a single-phase output from a crystal oscillator, 
clocks the CPU as well as the SYSC's internal state machine. 


The SYSC generates the AT bus clock, ATCLK, depending on the level of the BCLKS input. 
ATCLK is derived from either CLK2I/4 (BCLKS high) or CLK2I/6 (BCLKS low). An onboard, 2- 
position jumper establishes the level of BCLKS. 


2.3 Cache Subsystem 


The SYSC has a non-pipeline mode with a 16-byte line size to simplify design without 
increasing cost or degrading system performance. Note that a buffer is required between the 
cache and the CPU data bus. A tag comparitor is built inside the SYSC to improve system 
performance and reduce board real-estate. The comparitor asserts HIT# when the addressed 
location points to a current cache entry. If HIT# is negated or NCA# (Non-Cacheable Address) 
is asserted, the current cycle is a cache-miss; otherwise the cycle is a cache-hit. Descriptions 
of possible cache cycles follow. 


Cache-Read-Miss with the cache location's DIRTY bit negated. The cache controller 
does not need to update memory with the cache's current data, because that data is 


unmodified. The cache controller asserts TAGWE#, causing the tag RAMs to update 
with the new address, and asserts CAWE(3:0)#, causing cache memory to update with 
data from DRAM. 


Cache-Read-Miss with DIRTY asserted. The cache controller must update memory 
with data from the cache location that is going to be overwritten. The controller writes 
the 16-byte line from cache memory to the DRAM, then reads the new line from DRAM 
into cache memory. The controller asserts TAGWE# and CAWE(3:0). This cycle is 
called a two-way interleave cache read/write. 


Cache-Write-Hit. The cache controller does not need to update memory. The 
controller updates the tag RAMs and cache memory and sets the DIRTY bit. (DIRTY 
may already be set, but that does not affect this cycle.) 


Cache-Write-Miss. The cache controller bypasses the cache entirely and writes the 
line directly into DRAM. DIRTY is unchanged. 


The following table shows the cache sizes supported by the 82C491, with the corresponding 
tag RAM address bits, tag RAM size, cache RAM address bits, cache RAM size, and 
cacheable main memory size 


Tag RAM size /Cache RAMs 
4KX9 8 8KX8 
8KX9 16 8KX8 
16KX9 8 32KX8 


A25 - A19 A18 - A4 
32KX8 16 32KX8 


Tag SRAM 


*DRAM at minimum wait state 


2.4 CPU Burst Mode Control 


The use of a secondary cache guarantees that data is burst immediately into the CPU when a 
cacheable location is read, whether it is a read-hit or read-miss. BRDY# (Burst Ready) is 
asserted at the middle of the first T2 state when zero wait states are required and at the middle 
of the second T2 state when one wait state is required, except during a cache read miss; then, 
BRDY# is asserted after cache memory is updated. Once asserted, BRDY# stays high until 
BLST# (Burst Last) is detected. BRDY# is never active during DMA and MASTER cycles. 


2.5 Local DRAM Control Subsystem 


The SYSC supports up to 4 banks of page-mode local memory. DRAM devices are either 256- 
Kb,1-Mb or 4-Mb large. Total memory is between 1 Mb and 64 Mb. The following table 
illustrates the configurations supported. 


2.6 Shadow RAM 


Because DRAM accesses are much faster than EPROM accesses, the SYSC provides 
shadow RAM capability to enhance system performance.. BIOS is copied, then write- 
protected, into a dedicated area in DRAM. Accesses to BIOS address space are redirected to 
the corresponding DRAM location. Shadow RAM addresses range from CO000h to FFFFFh. 
Co000h to EFFFFh are enabled in 16-Kb memory chucks. FOOQOOh-FFFFFh, the location of 
system BIOS shadowing, are enabled in 64-Kb chucks. When shadowing is disabled (bit 7 of 
Index Register 22h is reset), BIOS is read from EPROM and (if applicable) written to DRAM. 


2.7 AT Bus State Machine 


The AT state machine monitors status signals, M16#, 1016#, Chrdy and Nows# from the AT 
bus. The machine outputs AT bus signals, including command, bus conversion, and control. 
The AT bus state machine also routes data and address when an AT bus master or DMA 
controller accesses memory. 


2.8 Bus Arbitration Logic 


82C391 arbitration is based on first-come, first serve basis. The SYSC arbitrates between 
memory requests from the CPU, DMA controller, AT bus masters, and refresh logic. During 
DMA and AT bus master write cycles, the SYSC asserts HOLD to the CPU, then the CPU 
relinquishes bus control, returning HLDA. The SYSC asserts AHOLD and BOFF# during an AT 
memory code read cycle. During refresh (and when hidden refresh is enabled), HOLD remains 
negated, and the CPU continues its current program execution as long as it achieves cache 
hits. 


2.9 Refresh Logic 


The SYSC supports both normal refresh and hidden refresh. The average refresh period (time 
between refresh cycles) is either 16us or 64us, the latter when slow refresh is enabled. (Slow- 
refresh DRAMs must be used with slow refresh.) Hidden refresh separates refreshing of AT- 
bus memory and local DRAM; the AT-bus controller arbitrates between CPU accesses to the 
AT bus, DMA, and AT refresh, while the DRAM controller arbitrates between CPU DRAM 
accesses and DRAM refresh cycles. Note that the DBC generates the refresh address during 
AT-bus refresh cycles. 


2.10 System BIOS ROM and 1/O Ports 


The SYSC supports both 8-bit and 16-bit EPROM cycles. If the system BIOS is eight bits 
wide, the system BIOS EPROM resides on the XD bus. If the system BIOS is 16 bits wide, 
the EPROM resides on the SD bus, and ROMCS# is connected to M16# through a open 
collector; ROMCS# informs the SYSC that the current system BIOS is 16 bits wide. The XD- 
bus data buffers always drive toward the XD bus, except during an I/O read cycle at an 
address smaller than FOh (byte-wide I/O) or during an 8-bit BIOS ROM cycle. 


2.11 Turbo Switch 


The system is operating at the full speed if the TURBO pin is asserted high. When TURBO is 
low, the SYSC holds the CPU during two thirds of the cycle, decreasing CPU performance by 
a factor of three. OUT1, which is connected to the TURBO pin and input to the 82C391, tells 
the SYSC whether or not to hold the CPU. 


2.12 Flexible Multiplexed DRAM Address 


The following table describes how the DRAM address lines are multiplexed when different 
memory devices types are used. 


Address to MA bus Mapping 


Mem 256K 1M 4M 
addr Col Row Col Row Col Row 


| mas | Ato | Ati | Ato | Azo | Ato | A20 | 
| Mag | xX | x Att | vat Ata at 
| Maio | x | x | x | x | Ata] Azz | 


3 SYSC SIGNALS DESCRIPTIONS 


3.1 Clock and Reset 


Rare _}_type Pin Nef ____Deserption —___ 


CLK2l Crystal oscillator Input which has a frequency 
equal to twice the rated CPU clock. This signal is 
used for secondary cache early write option only. 
phase. 

Se ATCLK Selection. 

Low ATCLK = CLKI/6. 
High ATCLK = one 


could be either cLKi/4 or CLKI/6. 
Pie epee 
power supply or from Reset Switch 
Oi a te 
from DBC's ERST2¢# pin. 


CPURST | O | _25__| Reset for 486 processor. 


3.2 CPU Interface 


| Name | Type | PinNo | ~——siDescription 


CA(31:24) 88-83,68-67 | CPU Address Lines 31-24. They are input pins 
during CPU cycle, and forced to be low for DMA 
and MASTER cycles which allow 486 invalidating 
the internal TAGs. Note that the CPU isn't on 
HOLD when AT refresh cycle undergoing. 


CA(23:21) [| 1 | 66-64 CPU Address Lines 23-21; Input only. 


CA20 63 CPU Address Lines 20; it's an input pin during 
CPU and DMA cycles, and becomes an output pin 
during MASTER cycle. 


CA(19:17) | 1 | 62-60 CPU Address Lines 19-17; Input only. 


CA(16:8) 59-51 CPU Address Lines 16-8. These are input pins 
during CPU and MASTER cycles. CA(16:9) are 
output pins for DMA address A16-A9 by latching 
XD(7:0) during 16-bit DMA cycle and CA(15:8) 
are DMA address A15-A8 for 8-bit DMA cycle. 


CA(7:2) | 1 | 49-44 CPU Address Lines 7-2; Input only. 


BE(3:0) 31-34 Byte Enable 3-0. These are inputs during CPU 
cycle and are outputs during DMA and MASTER 
cycle, derived from SAO, SA1 and SBHE# from 
AT bus. 


indicates the CPU is starting a new cycle. 
write cycle if high and read cycle. if low. 

CPU Data or Code Cycle Status. It indicates 
data transfer operations when high, or control 
operations(code fetch, halt, etc.) when low. 

a memory cycle if high, and I/O cycle if low. 
Indication of CPU local Bus device Cycle, i.e. 
Weitek 4167 coprocessor. This signal is 
sampled at the end of ist T2. 

486 burst last cycle indication, SYSC 
terminates the burst cycle as long as the 


BLST# sampled low at the end of each T2 
when BRDY# is active. 


cycle. This pin is not a tri-state output. 
synchronized by SYSC before sending to CPU. 
Burst ready output for CPU to sample the read 
data during burst cycles. This pin is a tri-state 
output. 

Cachable or non-cachable status for the 
internal cache of CPU. This signal is low 
normally, and is brought high at the end of T1. 
The SYSC will assert KEN# again if it is a 
cachable cycle. 

Backoff output for CPU. This output forces the 
80486 microprocessor to float its bus in the 
next clock. 

Turbo Mode Selection. | f Turbo pinis tied to 


low; the system runs at full speed, otherwise, 
the SYSC will hold two third of the CPU time. 


486 TLB Problem Fix. 


a 


MIO# 
LDEV# 


BLST# 


RDY|# 
BRDY# 


KEN# 


BOFF# 


TURBO 


iil al 
bore 


TLB# 


3.3 Numeric Processor Interface 


| Type | PinNo  ={| SC esccription 


—— 24 Numeric Processor Error Indication. Used to 
generate IGERR# for CPU. 


IGERR# 21 This is a normally high signal and will become 
low as soon as the NPERR# is asserted. An 
IO write to either port FOh or Fth, or CPU reset 
will force this signal back to high. 


3.4 External Cache Control 


77T- a ,69 TAG RAM Output Lines_ 7- 0. 


been written into. 
the TAG RAM. 


corresponds to one byte of data 
External Cache Even Bank Chip Select; it is 
normally active and becomes high if CA2 is 
high during cache write cycle. Also it will toggle 
during cache line fill cycle. 
External Cache Odd Bank Chip Select; it is 
normally active and becomes high if CA2 is 
low during cache write cycle. It will be a 
complement of BECS# during cache line fills. 
External Cache Even Bank Data Buffers 
Enable; Activated for cache write cycle and, if 
CA2 is low, cache read cycle. Also, toggles 
during dirty write backs and CPU burst reads. 
External Cache Odd Bank Data Buffers 
Enable. It is activated for cache write cycle 
and, if CA2 is high, cache read cycle. It will 
become a complement of BEOE# during dirty 
write back and CPU burst read cycle. 
External Cache Data Buffers Direction Control. 
It is normally high and forced to be low when 
writing data into cache. 


a 


nee 
TAGWE# 


DTYWE# 
WEGOE 


CAWE(3 


BECS# 


BEOE# 
BOOE# 


BDIR# 


a 
aor =| 
aoe 
Pp 


External Cache Even Bank Address Bit 3.It is 
tri-stated during T1 and first half T2 cycle. 
Then it simply reflects the status of CA3 and 
will toggle during dirty write back, cache line 
fill, and CPU burst read cycles. 

External cache oven bank address bit 3.It is 
tri-stated during T1 and first half T2 cycle. 
Then it reflects the status of CA3 and will 
toggle during dirty write back, cache line fill, 
and CPU burst read cycles. 

External cache address bit 3 select; use this 
signal to choose between CA3 and BEAS for 
even bank cache address bit 3, or BOA3 for 
odd bank cache address bit 3 respectively. 
becomes active for T1 and the first T2 cycles. 


| PinNo” | CCSCSCSCéessccription 
DRAM Write Enable signal. 


132,131,129, | DRAM Row Address Strobe. 
128 


CAS(3:0)# 127-124 DRAM Column Address Strobe. 


MA(10:0) 123,122, DRAM Row/Column Address Line 10-0. 
119-111 


3.6 DBC Interface 


Local Memory Acessed Indication. Used by 
DBC to control the bus flow. 


| Name _—|_Type__| 


LMEN# 


i 
107 DRAM Read Data Latch Enable; used for parity 
checking. 
MIO16# 143 Latched AT-bus 16-bit Slave Status; used for 
bus conversion. 
i 
a ae es ae 


PCKEN# Parity Checking Enable; used by DBC to 
perform parity checking 
AT Cycle Indication for CPU cycle 


ATCYC# 


3.7 Bus Arbitration 


[Name] 
OUT1 
HLDA 


ADS8 


DMA or Master Cycle Request from 82C206 


Refresh Request from Timer1 Output. 
41 CPU Hold Acknowledge. 


a 
152 8-bit DMA Transfer Address Strobe. The SYSC 
has to latch XD(7:0) by using ADS8 and 
translate to CA(15:8) outputs. 


AEN8# 8-bit DMA Cycle Indication. 


ADS16 153 16-bit DMA Transfer Address Strobe. The 
SYSC has to latch XD(7:0) by using ADS16 
and translate to CA(16:9) outputs. 

AEN16# Ft 148 | 16-bit DMA Transfer Indication. 


HOLD HOLD Request to CPU. Hidden refresh will not 
hold the CPU. 
== aa 


HLDA1 DMA or Master Cycle Granted Notice. 


158 AT Refresh Cycle Indication. It is an input pin 
during master or DMA cycle. 


2 Address hold request to CPU; It will be 
activated when HLDA is active and CPURST 
isn't active, or right after AT memory code read 
cycle if HOLD is pending. AHOLD will last until 
HOLD is end. 


2 486 address snooping strobe; it's asserted for 
two T states during DMA or MASTER cycles. 


RFSH# 


AHOLD 
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7 
2 
3 


EADS# 


3.8 AT-BUS Interface 


| Name | Type | PinNo | Description 


156 System Address Line 0. Input during master or 8-bit DMA 
cycles; output pin during CPU, 16-bit DMA, or refresh cycle. 


ee ies, ee System Address Line 1, it is an input pin during master or 
DMA cycle; becomes output pin during CPU or refresh cycle. 
| CHRDY | | | 139 | Channel Ready Input from AT-BUS. Schmit trigger input pin. 
NOWS# 138 Zero Wait State Input from AT-BUS. It is a schmit trigger 
input pin. The system BIOS ROM is treated as AT one wait 
state cycle. 


loi6# | | | 137 — | 16-bit |O Slave Cycle Status. It is a schmit trigger input pin. 
mie# | | | 136 | 16-bit Memory Slave Cycle Status; Schmitt trigger input pin. 


GATEA20 141 Gate A20 Input from 8042 or DBC emulated gateA20 pin. By 
default, SYSC uses this signal to qualify CA20 during CPU 
cycle. 

Kenic es eee Sees apeaaee ANDed with fast GATEA20 output to CPU; it will 
remain high during power up CPU reset period. 
9-11,13-17 | Peripheral Data Bus Line 7-0.Two purposes for these pins: 
program the internal index register.* latch the DMA high order 


address. 


ee ee 
master cycle. 
ot 
master cycle. 
jee eh AT Memory Read Command. It is an input pin during DMA or 
master cycle. 
Baal Nall SA ~~" -emabncriaenla 
master cycle. 
Rel il ca ory 
to be activated during refresh cycle. 
| SBHE# [| O | 155 | AT Bus High Enable. Itis an input pin during master cycle. | 


SMWR# de AT Memory Write Command, for address below 1 MB 
memory space. 
ALE 


AT Bus Address Latch Enable to represent that the AT cycle 
has started. It is brought to high during non-CPU cycle. 
Interrupt Acknowledge Cycle Indication. Hold will not send to 
CPU between the INTA* cycles. 

System BIOS ROM Output Enable. System BIOS ROM 
accessing could be either 8-bit or 16-bit. This signal will be 
asserted from the end of the first T2 to the end of the last T2. 


3.9 Ground and VCC 


Po PiNoCeescription __| 


1,20,40,81,100,120 
12,30,50,70,80,90,108,121,130,150,160 VSS or Ground 


4 SYSC REGISTERS DESCRIPTIONS 


There are twelve configuration registers inside the 82C491. An indexing scheme is used to 
access all the registers of OPTi-486WB chipset. Port 22h is the index register and port 24h is 
the data register. The index resets after every access; thus, every data access (via port 24h) 
must be preceded by a write to port 22h, even if the same register is being accessed. All 
reserved bits are set to zero by default and must be set to zero for future compatibility 
purpose. 


Control Register 1 
Index: 20h 


FAULT 
Cache memory data buffer output enable control 
0 =disable 1 = enable 
When enabled, it will be activated half T stste earlier during 
read hit cycle. 
Single ALE Enable- SYSC will activate single ALE instead of 
multiple ALEs during bus conversion cycle if this bit is 
enabled. 


Keyboard and Fast Reset Control - turn on this bit requires 
"Halt" instruction to be executed before SYSC generates 
CPURST. .from keyboard reset 

0 =disable 1= enable 


Control Register 2 
Index: 21h 


Master Mode Byte Swap Enable 
0 =disable 1 = enable 
Fast Keyboard Reset Delay Control 
0 = Generate reset pulse 2 us later 
1 = Generate reset pulse immediately 

Parity Check 
0 =enable 1 =disable 

4 Cache Enable 

0 = Cache is disabled and DRAM burst mode is enbled 
1 = Cache enable and DRAM burst mode is disabled 


Cache Write Wait State Control 
0= 1 Wait state 
1 = 0 Wait state 


3-2 Cache Size 
32 Cache Size 
00 64KB 
01 128KB 
10 256KB 
11  512KB 
1 Secondary Cache Read Burst Cycles Control 
0=3-1-1-1 Cycle 
1=2-1-1-1 Cycle 
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Shadow RAM Control Register | 
Index: 22h 


FUNCTION DEFAULT 


ROM Enable 1 
1 = read from ROM, write to DRAM. 

0 = read/write on RAM and DRAM is write-protected 

Shadow RAM at DOOOOh - DFFFFh Area 

0 = Disable 1 = Enable 

Shadow RAM at E0000h - EFFFFh Area 

0 = Disable 1 = Enable 


[ 
Ls 
4 Shadow RAM at DOO00h - DFFFFh Area Write Protect 
Enable 
0 = Disable 1 = Enable 
ae 
Ls 


Shadow RAM at E0000h - EFFFFh Area Write Protect 

Enable 

0 = Disable 1 = Enable 

Hidden refresh enable (without holding CPU) 1 
1 = Disable 0 = Enable 


(OU Ue a ee ee eS ed 


1 
Slow Refresh Enable (4 times slower than the normal refresh) 0 
= Disable 1 = Enable 


Shadow RAM Control Register Il 
Index: 23h 


Shadow RAM at ECOOOh-EFFFFh area Lo 
0 = Disable 1 = Enable 

a Shadow RAM at E8000h-EBFFFh area Loe 
0 = Disable 1 = Enable 

Shadow RAM at E4000h-E7FFFh area [al 
0 = Disable 1 = Enable 

Shadow RAM at E0000h-E3FFFh area Le 
0 = Disable 1 = Enable 


Shadow RAM at DCO00h-DFFFFh area Lo 
0 = Disable 1 = Enable 

Shadow RAM at D8000h-DBFFFh area Loe 
0 = Disable 1 = Enable 

Shadow RAM at D4000h-D7FFFh area Le] 
0 = Disable 1 = Enable 

az Shadow RAM at DO0000h-D3FFFh area a 
0 = Disable 1 = Enable 
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DRAM Control Register | 
Index: 24h 


BIT DEFAULT 
7 0 = 256 K DRAM mode 
table 


3 Fast decode enable. This function may be enabled in 20/25 
Mhz operation to speed up the DRAM access. 
0 = Disable fast decode, DRAM wait state is not changed 
1 = Enable fast decode, DRAM wait state is decreased by 1 
This bit is automatically disabled even when it is set to 1 when 
bit 4 of Index register 21h(cache enable bit) is enabled. 


SF ee A 
7654 
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DRAM Control Register II 
Index: 25h 


Read cycle wait state 

7 6 Additional wait States 
00 Not used 

01 


Write cycle wait state 
3 Additional wait states 
0 0 
1 


0 
0 
0 3 

1 not used 

ATCLK selection, bit 0 will reflect the BCLKS pin status when 

82C493 is reset. Bit 0 is 0 if BCLKS is tighted low and 1 if depending the 
BCLKS is high low or high of 
1 0 ATCLK selection BCLKS 

0 O (default) : ATCLK = CLKI/6 respectively 
0 1 (default) ATCLK = CLKI/4 

10 ATCLK = CLKI/3 

11 ATCLK = CLK21/5 


Shadow RAM Control Register III 
Index: 26h 


FUNCTION DEFAULT 


Shadow RAM copy enable for address area CO000h-CFFFFh 
0 = Read/write at AT bus 
1 = Read from AT bus and write into shadow RAM 


Shadow RAM enable at COOO0Oh- CFFFFh area 
0 = Enable 1 = Disable 


5 Shadow write protect at address area COO00h-CFFFFh 
0 = Write protect disable . 
1 = Write protect enable 
a 
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a 

0 = Disable 1 = Enable 

Se -nea 
0 =disable 1 = Enable 


Enable shadow RAM at C4000h-C7FFFh area a 
0 = Disable 1 = Enable 

hosed Enable shadow RAM at CO000h-C3FFFh area ed 
0 = Disable 1 = Enable 
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Control Register 3 
Index: 27h 


Enable NCA# pin to low state, 0=Disable 1 =Enable 
cUinmseds Fe eh 
1 


0 = Cacheable 1 = Non-cacheable 


Cacheable address range for local memory, see following table 0001 


Note. Memory area at 640K-1M is defaulted to be non-cacheable. 


a Cachable Address range 


Note: If total memory is 1 Mb or 2Mb, the cacheable range is 0 - 1 or 0 - 2Mb respectively and 
indendent of the value of bit 0-3. . 


Video BIOS at +C0000h-C8000h area non-cacheable 
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Non-cachable Block 1 Register 
Index: 28h 


This register is used in conjunction with Index 29h register to define a non-cacheable block. 
The starting address for the Non-Cacheable Block must have the same granularity as the block 
size. For example, if a 512 Kb non-cacheable block is selected, its starting address is a 
multiple of 512 Kb; consequently, only address bits of A19-A23 are significant, A16-A18 are 
“don't care". 


aca a 0 ee ES A ee 
| 10 | Address bits of A25 and A24 of non-cachable memory block 1 | 00 


Block Size 


a ae a ae 


Non-cachable Block 1 Register Il 
Index: 29h 


BIT FUNCTION | Default | 
Address bits A23-A16 of non-cachable memory block 1 0001xxxx 


aaa Valid Starting Address Bits 


x = Don't Care 
V = Valid Bit 
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Non-cachable Block 2 Register | 
Index: 2Ah 


This register is used in conjunction with Index 2Bh register to define a non-cacheable block. 
The starting address for the Non-Cacheable Block must have the same granularity as the block 
size. For example, if a 512 Kb non-cacheable block is selected, its starting address is a 
multiple of 512 Kb; consequently, only address bits of A19-A23 are significant, A16-A18 are 
“don't care". 


NAS eee eee es ee 
| 10 | Address bits of A25 and A24 of non-cachable memory block 1 | 00 


| 000 | 4K 


Non-cachable Block 1 Register Il 
Index: 2Bh 


BIT |FUNCTION, Default 
Address bit A23-A16 of non-cachable memory block 1 0001xxxx 


fee ao Valid Starting Address Bits 


| BlockSize | A23 | a22 | a2t | azo | aig | ais | ai7 | At6 | 
ve 


64K 


x = Don't Care 
V = Valid Bit 
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5 82C392 DATA BUFFER CONTROLLER(DBC) 


The DBC is a 160-pin PFP (Plastic Flat Package) device. The DBC integrates data buffers, 
AT bus control, decode logic for an external keyboard controller, reset logic, and clock 
generation logic.. It performs the following functions: 


data bus conversion 

parity generation/detection 

AT-BUS direction control 

reset logic 

clock source for 206 and 8042 

chip select for keyboard controller and RTC 
speaker control 

port B, 70H and NMI Logic 

floating-point coprocessor interface 
keyboard reset and gate A20 emulation logic 


ooo0o0o0o0o00 0 


5.1 Data Bus Conversion 


The DBC performs data bus conversion when the CPU accesses 16- or 8-bit devices through 
32- and 16-bit instructions. The DBC also handles DMA and AT bus master cycles that 
transfer data between local DRAM or cache memory and locations on the AT bus. The DBC 
provides all of the signals necessary to control external bidirectional data buffers. 


5.2 Parity Generation/Detection Logic 


During local DRAM write cycles, the DBC generates a parity bit for each byte of write data from 
the processor. Parity bits are stored in dedicated local DRAM. Within the timing window of 
"PCKEN" during a DRAM read, the DBC checks if each parity bit is correct for its 
corresponding data byte. If it detects incorrect parity, the DBC generates a parity error. 


5.3 Clock Generation and Reset Control 


The DBC provides the clock sources for timer 1 of the 80C206 and for the 8042 keyboard 
controller to reduce the components count. The clocks are derived from 14.3 Mhz. The 
00C206 clock is 1.19 Mhz. (14.3Mhz divided by 12). The 8042 clock is 7.15 Mhz. (14.3Mhz 
divided by 2.) The DBC also monitors both the PWGD# (Powergood) signal from power supply 
and the reset signal, RST1. from the reset switch. The DBC routes RST1 to the SYSC to 
generate the "cold reset". The DBC can also supply the RST2 keyboard controller "warm 
reset" sequence, or RST2 can come from the keyboard controller. The reset sequence is 
much faster when the DBC supplies RST2. 
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5.4 Floating-Point Coprocessor Interface 


The DBC monitors NPERR# and NPBUSY# to provide support for 387 and 3167 floating-point 
coprocessors. (The 486 has an internal coprocessor and does not need this support.) A 
coprocessor asserts NPERR# during a power on reset. to indicate it is there.. The coprocessor 
asserts NPBUSY# while executing a floating-point calculation, and asserts READY# when it is 
finished. If NPBUSY# is active and a coprocessor error occurs (the coprocessor asserts 
NPERR#), the DBC latches NPBUSY# and generates INT13. INT13 also come from WINT# 
from the Weitek 3167 coprocessor. Latched BUSY# and INT13 can be cleared by a I/O port 
FOH write command. 


6 82C392 (DBC) PIN DESCRIPTIONS 


6.1 Clock and Reset 


| Name] Type 


| PinNo | iDesscription 
Power Good Status from power supply. It is 
buffered through a Schmitt-trigger gate. 
Reset Switch Input. It is buffered through a 
Schmitt-trigger gate. 
10 Power-up or cold Reset signal derived from 
Led PWGD# or RSTSW. 


PWGD# 
RSTSW 
RST1# 


aa 
P= On =i 
cS ae 
Oe 
tO] 
| osc2#_ | 
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6.2 Address and Data Buses 


| PinNo = {| Ci escription 
D(31:23) 
D(22:14) 
D(13:5) 
SBHE# 


checking of valid byte. 
MD(31:26) 
MD(25:17) 
MD(16:8 


99-96 XD Data Lines 3-0. 


[| Name 


HLDA Hold Acknowledge from CPU in response to 
hold request 
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6.4 SYSC Interface 


Interrupt Acknowledge; for data flow direction. 
System BIOS ROM Chip Select,, used to 
direct the data bus flow. 

Local Memory Enable. Indicate the current 
cycle is local DRAM Access. It is used to 


control the bus direction. 


CPU Write or Read Cycle Indication 


17 DRAM Read Data Latch, used to latch the data 
for parity checking. 
DRAM Write Enable, to enable DRAM write. 


INTA# 


ROMCS# 


LMEN# 


Le 
a a a 
| DWe# | 
Macca 
ieee ee 
fe he =2) 
ee] 
ae 
a 


MIO16 


access is AT bus cycle. 
Parity Checking Enable, to enable the Parity 
error signal if any. 


used to control the data flow path. 


6.5 Floating-Point Coprocessor Interfaces 


* Note these signals won't be necessary in 486 processor. 


[| Name |] Type 
NPERR# 


NPBUSY# 


Error from the coprocessor. It is an active low 
input indicating that an unmasked error 
happens. 


| PinNo 
coprocessor instruction is under execution. 
| 89_~| ResetNumeric Processor 
34 Latched Coprocessor Busy Output to 80386 to 
S| indicate a NPBUSY# or NPERR# signals has 
occurred. 

Busy Toggled Control; used to toggle the 
Ls BUSY# signal when the coprocessor is not 

installed. 


BUSY# 
BSYTOG# 


| NPRST | OO 
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| Name__—|__Type__| 
INT13 Coprocessor Interrupt; is an active high output. 

It is an interrupt request from numeric 

coprocessor and connected to IRQ13 of 


interrupt controller. 


Mie 
ERR# 33 Error signal to 80386. It reflect the NPERR# 
signal during the period from RST4# active to 
first ROMCS#. 
pa de = = 92 
p— 20" a 


WINT Weitek 3167 Co-processor Interrupt Request. 
PREQI 80387 coprocessor Request Input. 
PREQO Numeric Processor Request to 80386. 


6.6 Miscellaneous Signals 


| Type | PinNo Description 

Keyboard Controller Chip Select. 

95 Non-maskable Interrupt; due to parity error 
from local memory or AT bus channel check. 
Speaker Data Output, derived from the function 
of OUT2 and port 61H bit1. 

93 Timer 2 Gate Control. 

94 Real Time Clock Address Strobe. 

29 AT-BUS Channel Check. 

44 

5 

7 

19 


oe Timer 2 output. 


[| Name 
KBDCS# 


SPKD 


FAST is an active high input which will enable 
the emulation of Fast GATEA20 and Reset 
Control Enable. 

GateA20 output. It is generated by emulating 
Keyboard GATEA20. 

RST2# output. It is generated by emulating 
keyboard RST2#. 

Master Access Local DRAM invalidation. 
MD-bus to SD-bus Buffer Enable Signal. 


MD(7:0) to SD(7:0) Buffer Direction Control. 
MD(15:8) to SD(15:8) Buffer Direction Control. 


EGTA20 
ERST2# 


a 
[= 30) =] 
a: a 
= 
for 
ad oa 
[202 | 
[nce | 
fa SOs. 2 
pe 200s“ 
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6.7 Ground and VCC 


PC PinNo STs eessccrription | 
20,40,86,100,140 


1,40,41,50,70,80,81,120,121,130,150,160 VSS or Ground 


7 82C392(DBC) REGISTERS DESCRIPTIONS 


Control Register Index 21h(write only) 


Bit 7-4 is a duplication of control register index 21h of 820491. 
Bit 3-0 are not used. 


V/O Port 60h 


Port 60h and 64h emulate the registers of a keyboard controller, allowing the generation of a 
fast gate A20 signal. The sequence here is BIOS transparent, and there is no need for the 
modification of the current BIOS. The fast gate A20 generation is enabled when the "Fast" pin 
is wired high. The sequence involves writing data D1h to port 64h, then writing data 02h to port 
60h.When "Fast" is asserted, I/O port 60h indicates the status of a system reset (bit 0) and 
gate A20 (bit 1). 


/O Port 61h(Port B) 


Refresh Detect. 


Timer OUT2 Detect. 


I/O Channel Check. 
System Parity Check. 
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/O Port 64h 


I/O port 64h emulate the register inside a keyboard controller by generating a fast reset pulse. 
Writing data FEh to port 64h asserts the reset pulse. The pulse is generated immediately after 
the I/O write if bit 6 of Index 21h is set, otherwise the pulse is asserted 2us after the write. 


Port 70h 
| Cit ——s|_ Ss Read/write | Function ~———s|~——Polarity 
RW NMI Enable a2 


34 


